草庐IT

sql - MySQL数据版本控制

全部标签

sql - 在 Rails 中使用连接执行 update_all

在这种情况下,Rails对原始SQL的抽象让我抓狂。在MySQL中我可以这样做:UPDATEFROMtasksAStLEFTJOINprojectsaspONt.project_id=p.idSETt.invoice_id=7WHEREp.organization_id==42ANDt.invoice_idISNULL我如何在Rails3.0.1中使用预先加载来做到这一点?我已经尝试了以下所有方法:Tasks.joins(:project).where('projects.organization_id'=>42,:invoice_id=>nil).update_all(:invoic

sql - 如何查看 SQL ActiveRecord 生成的内容?

我想检查一些由ActiveRecord生成的查询,但我不需要实际运行它们。有没有办法在返回结果之前获取查询? 最佳答案 这两篇文章都应该可以帮助您做您想做的事。http://weblog.jamisbuck.org/2007/1/8/watching-activerecord-do-it-s-thinghttp://weblog.jamisbuck.org/2007/1/31/more-on-watching-activerecord 关于sql-如何查看SQLActiveRecord生

ruby-on-rails - 更改 bundle 安装 Ruby 版本

我是Ruby/Rails的新手,如果这是一个微不足道的问题,请原谅我。每当我运行bundleinstall时,它都会在vendor/bundle/ruby/1.8中安装所有内容,而不是vendor/bundle/ruby/1.9.1,这是我正在使用的Ruby版本。当我运行ruby-v时,我得到了正确的1.9.1版本,但是bundleinstall出于某种原因坚持使用1.8,这导致了基本Rails功能的许多错误。如何指示bundle与1.9.1一起工作(最好删除任何Ruby1.8的踪迹)?谢谢!编辑:我已经做了一切this回答说,我没有得到1.8的踪迹再次编辑:好吧,它以某种方式工作。也

sql - 用于 250K+ 字符串的通配符搜索的 Fast(er) 方法

我在MySQL数据库中有一个英语词典,其中只有超过250K个条目,我正在使用一个简单的ruby​​前端在字符串的开头使用通配符来搜索它。到目前为止,我一直这样做:SELECT*FROMwordsWHEREwordLIKE'_e__o'甚至SELECT*FROMwordsWHEREwordLIKE'____s'我总是知道单词的确切长度,但除了一个字符之外的所有字符都可能是未知的。这比糖蜜慢,比没有前导通配符的类似查询慢大约15倍,因为无法使用该列的索引。我尝试了几种方法来缩小搜索范围。例如,我添加了26个额外的列,其中包含每个单词的单个字母计数,并首先使用这些列来缩小搜索范围。我也试过按

ruby-on-rails - Ruby 哈希可以包含在 Sass 和 CoffeeScript 中,从而允许共享数据吗?

我想知道是否可以在Sass和CoffeeScript之间轻松共享ruby​​哈希。我四处寻找这个问题的答案,但没有找到任何结论。来源,例如documentation对于Sass,谈论如何链接相同类型的文件以及如何在语言内操作数据结构,但不要触及是否可以从其他地方导入数据,或者是否可以以某种方式解释ruby​​代码——我唯一类似的事情可以想到的是compass使用.rb文件作为它的配置。我的直觉表明这是(或应该)可能的,这两种语言都类似于Ruby,并且能够解释哈希值。因为这是一个实际问题,我遇到过好几次(干掉预处理的前端代码,但也为后端处理提供相同的值,例如在HTML模板中生成SVG)但

ruby-on-rails - 设置没有种子数据的数据库

我需要用表格等设置我的数据库,但在某些情况下我不想加载我的种子数据。我也不想每次想忽略我的种子数据时都删除或移动我的db/seeds.rb文件。有没有办法执行rakedb:setup的任务并忽略种子数据? 最佳答案 是的。只需使用以下两个命令:rakedb:createrakedb:schema:loadrakedb:setup所做的只是创建数据库(db:create),从db/schema.rb加载数据(db:schema:load),然后插入种子数据(db:seed)。您可以单独执行这些步骤。

ruby - 使用 Sinatra 时如何控制静态 Assets 的缓存?

很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visitthehelpcenter.关闭10年前。我使用的是最新的Sinatra,并且托管在Heroku上。有没有一种方法可以为从/public目录提供的静态Assets设置缓存header?Sinatra在检查任何已定义的路由之前从/public目录提供文件,所以我不能只在路由中使用cache_control方法。/public目录包含我的应用程序的CSS和JavaScript。我不希望浏览器每次都下载这些文件,因为它们不会经常更改。

ruby-on-rails - Rails - 如何禁用所有控制台日志记录?

来自javascript背景,我发现运行rails时的命令行很困惑。每当有事情发生时,我的命令行就会充满一堆废话。例如:[2013-06-1920:25:53]WARNCouldnotdeterminecontent-lengthofresponsebody.Setcontent-lengthoftheresponseorsetResponse#chunked=true如何关闭此功能以便我只看到自己的日志(当然还有错误)?感谢任何帮助! 最佳答案 尝试更改日志级别,默认为信息。来自指南:http://guides.rubyonrai

ruby - 如何更改 ruby 版本

我的Ubuntu机器上安装了Ruby1.8和1.9。我刚刚从ppa:brightbox/ruby-ng-experimental安装了Ruby2.0.0来安装一个需要2.0.0的包。现在所有1.8、1.9和2.0都已安装,但我不能告诉bundle使用2.0:$bundleinstall$YourRubyversionis1.9.3,butyourGemfilespecified2.0.0RVM无法更改版本:$rvm2.0$ruby-2.0.0-p451isnotinstalled.$Toinstalldo:'rvminstallruby-2.0.0-p451'RBENV也不识别2.0:

ruby-on-rails - Development.log 日志文件不记录 Rails SQL 查询

我在这里关注MichaelHartl的Rails教程:http://ruby.railstutorial.org/chapters/modeling-and-viewing-users-one#top我使用此命令在单独的窗口中跟踪SQL查询:tail-flog/development.log然而,当我在沙盒Rails控制台中时,日志不会用SQL语句更新,而是显示在Rails控制台中。我该如何纠正这种行为?我应该补充一点,我的数据库迁移和对数据模型(新表等)的更改都反射(reflect)在日志中。仅省略由Rails控制台内的方法传播的SQL语句(而是显示在Rails控制台中)。这是我的G